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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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1 Scope 

This document specifies the stage 1 requirements for realisation of an Open Service Access (OS A). 

OS A enables applications to make use of network functionality through an open standardised interface (the OSA API). 
OSA provides the glue between applications and network functionality. In this way applications implementing the 
services become independent from the underlying network technology. 

Applications which make use of network functionality offered through the OSA interface are not standardised by 3GPP. 

The network functionality offered through the OSA interface may or may not be standardised by 3GPP. 

OSA is one toolkit, amongst others, that enables certain aspects of the requirements of the Virtual Home Environment 
(VHE) concept to be realised. 

2 References 

The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of pubhcation, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

2.1 Normative references 

[1] 3GPP TS 22.121: Universal Mobile Telecommunications System (3G); "The Virtual Home 

Environment" 

[2] 3GPP TS 22.101: Service principles 

[3] 3GPP TR 21.905: Vocabulary for 3GPP Specifications 

[4] 3GPP TS 23 . 1 07 : QoS Concept and Architecture 

[5] 3GPP TS 22.024: Description of Charge Advice Information (CAI) 

[6] 3GPP TS 29.198: Open Service Architecture; Application Programming Interface; Part 1 

[7] 3GPP TS 22.141: Presence Service Stage 1 

2.2 Informative references 

[10] World Wide Web Consortium Composite Capability/Preference Profiles (CC/PP): A user side 

framework for content negotiation ( www.w3.org ) 

3 Definitions and abbreviations 
3.1 Definitions 

For the purposes of the present document, the following terms and definitions apply: 
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Access Rules: For the definition see [7]. 

Applications: software components providing services to users by utilising service capability features. 

Application Interface: standardised Interface used by applications to access service capability features. 

Availability: a property of a user denoting his/her ability and willingness to communicate based on factors such as the 
identity or properties of the requester of the information and the preferences and/or policies that are associated with the 
user. This property may be computed through information available from various capabilities within the network 
including (but not necessarily) the presence service. 

Call: A logical association between several users (this could be connection oriented or connection less). This pertains 
to the CS CN domain, the PS CN domain and the IP Multimedia Subsystem. 

Charging: A function whereby information related to a chargeable event is formatted and transferred in order to make 
it possible to determine usage for which the charged party may be billed. 

HE-VASP: Home Environment Value Added Service Provider. For the definition see [3] 

Home Environment: For the definition see [3] 

Local Service: For the definition see [1] 

Personal Service Environment: For the definition see [1] 

Policy: is a formalism that may be used to express business, engineering or management criteria. A policy is 
represented by a set of rules. Rules are expressed as condition(s)-actions(s) pairs. When the conditions associated with a 
rule are satisfied the associated actions are executed. 

Note: Policies created by applications are matched against the policies of a Network. 

Policy Event : A policy event is associated with the action part of designated rule(s). The event is generated when the 
action part is executed. 

Policy Management: is the capability to create, modify and delete policy related information, including policy events. 

Policy Enabled Service: is a Service which has some or all of its properties expressed in terms of policy rules. E.g. 
Charging Service wherein charging criteria are expressed in terms of policy rules 

Policy Decision Point: A function of the network where the applicable policy is chosen. 

Policy Enforcement Point: A function of the network where the chosen policy is applied. 

Policy Repository: A function of the network where policies are stored. 

Policy Enabled network: is a network that supports at least one instance of a Policy Repository and Policy Decision 
Point and Policy Enforcement Point. 

Presence Service: For the definition see [7]. 

Presence Information: For the definition see [7]. 

Presence Entity (presentity): For the definition see [7]. 

Service Capabilities: bearers defined by parameters, and/or mechanisms needed to realise services. These are within 
networks and under network control. 

Service Capability Feature: functionality offered by service capabilities that are accessible via the standardised 
application interface. 

Service Provider: an organisation which delivers services to the subscriber. This can be e.g. the operator of the 
subscriber's Home Environment or an authorised VASP. 

Note: In the context of this specification it is assumed, that at least one application providing the services of the Service 
Provider makes use of OS A functions 

Services: a service is the user experience provided by one or more applications. 
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User: For the definition see [1] 

Virtual Home Environment: For the definition see [1] 

Watcher Information: For the definition see [7]. 

Further 3G related definitions are given in 3G TR 21.905 [3]. 



3.2 



Abbreviations 



For the purposes of this TS the following abbreviations apply: 

API Application Programming Interface 

CAMEL Customised Application For Mobile Network Enhanced Logic 

HE Home Environment 

PSE Personal Service Environment 

VHE Virtual Home Environment 

OSA Open Service Access 

SCF Service Capability Feature 

MExE Mobile Execution Environment 

Further 3G related abbreviations are given in 3G TS 21.905 [3]. 



4 General Description of OSA 

In order to be able to implement future applications/end user services that are not yet known today, a highly flexible 
Framework for Services [1] is required. The Open Service Access (OSA) enables applications implementing the 
services to make use of network functionality. Network functionality offered to applications is defined in terms of a set 
of Service Capability Features (SCFs). These SCFs provide functionality of network capabilities which is accessible to 
applications through the standardised OSA interface upon which service developers can rely when designing new 
services (or enhancements/variants of already existing ones). 

The aim of OSA is to provide a standardised, extensible and scalable interface that allows for inclusion of new 
functionality in the network with a minimum impact on the applications using the OSA interface. 



5 The role of OSA within the VHE framework for 

services 

The goal of standardisation in 3GPP with respect to services is to provide a framework within which services can be 
created based on standardised service capability features (c.f. [1]). 3GPP services will generally not rely on the 
traditional detailed service engineering (evident for supplementary services in second-generation systems), but instead 
provides services using generic toolkits. 

OSA is one of these toolkits, standardised within 3GPP, for the support of services within 3GPP system (see chapter 
5.1). 

Services can be implemented by applications using service capability features [1], which are accessible via the OSA 
interface towards these SCFs in the network. 
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Figure 3: Applications access Service Capability Features 
via the standardised OSA Application Interface 



5.1 Physical location of applications using the OSA interface 

The physical location of applications accessing the OSA application programming interface is an implementation 
matter. This TS places no requirements on the physical location of the applications accessing the OSA application 
programming interface. 

The only requirement on such applications accessing the OSA application programming interface is that they shall only 
do so via the framework for services [ 1 ] . 

The architectural support of the OSA application programming interface shall permit applications access to the OSA 
API independent of where the appUcations are physically executing. 



High level requirements to OSA 



The following high level requirements apply to the OSA appUcation programming interface (API). The standardised 
API shall be: 

independent of vendor specific solutions; 

independent of programming languages, operating systems, underlying communication technologies, etc. used 
in the service capabilities; 

secure, scalable and extensible; 

independent of the location where service capabilities are implemented; 

independent of supported server capabilities in the network; 

independent of the transport mechanism between the service capability features server and the application server; 
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It shall be possible for an OS A application to continue operation in case of a consecutive upgrade of the 
underlying OSA capabilities. This ability to operate may be limited to a specific time period which is managed 
by the network operator. 

Access to Service Capability Features shall be realised using modern state of the art access technologies, e.g. 
distributed object oriented technique might be considered.; 

OSA shall be aligned as far as possible with equivalent work in other bodies, such as ETSI SPAN,Parlay and 
JAIN; 

OSA shall allow applications access to home network service capability features. Access to Service capability 
features other than those provided by the home network is not required; 

It is not required that network entities, which provide the implementation of OSA interfaces (SCFs), be 
mappable to 3GPP standardised functionality, nor that the existence of a standardised interface / protocol to 
communicate with 3GPP standardized network elements is required. Thus it is permissible to e.g. build a OSA 
API function into a WAP gateway to retrieve terminal capabilities from terminal supporting the WAP protocol. 

Note: If the network entity, to which OSA provides an API interface, is a 3GPP standardised entity and if a 
standardised interface / protocol to communicate with that network entity exists it is recommended that 
3GPP defines a mapping of the OSA API functions to that interface / protocol. 



7 Requirements for user data management 

The User Profile logically is a set of information relevant for a given user. The set of information is provided by Service 
Capability Servers and - if permitted - from Value Added Services. The amount of User Profile information might be 
distributed over various physically separated entities. The concept of distributed information is not within the scope of 
this specification. The detailed content of the User Profile is not subject herein. 

However, subscribers are able to subscribe or use services provided from Value Added Service Providers. Subscriber 
may customise these VAS according to their needs equally as the subscriber customise her services provided by the 
network operator. To avoid malicious or conflicting situations it is needed to allow VAS to access the users USER 
Profile. The co-existence of several services and the correct inter-working between them are founded on sufficient 
information about other services subscribed to. 

VAS shall not be allowed to access the User Profile without permission. It is important to prevent the User Profile from 
malicious attacks. The OSA Framework functions restrict the applications' access to the User Profile Management 
(UPM) functions. 

UPM functions check the application's rights to make these actions regarding each separate part of the user profile. 
Depending on the authorisation, the User Profile Management functions may permit the VAS to read from and/or to add 
to and/or to modify the User Profile or parts of it. This decision is based on: 

• Subscriber identity 

• Access information in the User Profile of the subscriber 

• Application identity 

• Access type (read, add or modify) 

Access information shall contain the user specific access rights per application. These may be given either for 
individual parts of the User Profile or for a group of data or even all data in the User Profile. 

The figure below gives a logical overview of the relation between VAS, User Profile Management function and the 
User Profile itself. 
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Note: the dotted line refers to additional Personal Settings. The reference itself shall unambiguously identify the 
location of the additional personal settings. 

User specific information from the e.g. HLR and/or HSS are equally part of the User Profile as terminal settings and 
VAS specific preferences. The User Profile in principle is the summary and collection of information with a relevance 
for the services supported for a given subscriber. 

The figure above shows User and Network Service and VAS specific information, customised by the user. It is 
assumed that the user profile consists of several parts. The User Profile elements shall at least be capable to store a 
reference to additional information stored else where. The User Profile shall act as a root towards all user specific 
information. 

Even when the content of the User Profile is outside this specification, the following figure shows how a content could 
look like. 
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•Telecom Subscribers Identity 
'Subscri bed Tel ecom Servi ces 
'MultipleSubscriber Profiles 
•Authentication Information 
•CAMEL Service Ret & Trigger 



m 



•Terminal Capability 
•Link to Settings & References 
•Reference to WAP Gateway 
•Reference to other Gateways 



•Reference to Service 1 e.g. 
Unified Resource Locator 




• Reference to Servi ce 2 e.g. 
Object Reference 



•Reference to Service Broker, 
e.g. Server Identity 



On the left side of the figure above, typical 3GPP system related information are listed (this is not an exhaustive list). 

The right side depict references to VAS specific information. The representation of references to V AS specific 
information above, is an example and does not insist to be complete. 



8 Charging requirements 



The charging functionality of OS A allows an application to raise a charge against a subscriber's account for goods and 
services provided to her. It enables the invoicing, by the operator, of soft (e.g. download of software, music,...) and hard 
goods (e.g. CDs, books,...), which potentially are provided by third parties. 

Additionally, the charging functionality of OS A shall provide for the maintenance of non-monetary subscriber accounts. 
An application may add or deduct non-monetary units to or from these accounts. 

The responsibility for the subscriber accounts can be assigned to either the home network or elsewhere.: 

• If the home network does not handle the accounts itself, charging requests are sent from the home network (and 
possible other applications) to a dedicated charging application, typically a charging centre. This case is out of 
scope of OS A. 

• If the accounts are handled by the home network, the operator takes care of them. 

They may be used to charge for network resource usage {call charging, as it is done today) as well as any non- 
telecommunication related activity (any E-commerce activity like service usage, online purchases...) 

OSA shall provide sufficient functions to support charging when the accounts are handled by the home network. 

Two cases need to be considered in more detail: 

Call and Event Charging: OSA shall enable applications to control the charge of a call and / or an event that is 
under supervision of this application. OSA shall allow an application to provide additional charging information 
to the network; 

Service Usage (e.g. Online Purchases): On the other hand, OSA shall allow to employ the charging capabilities 
of the network to charge subscribers for any kind of service or even online purchases. Calculation of the charge 
may be based on monetary and/or non monetary grounds. 
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Beyond this, there are general charging functions on subscriber accounts (monetary and non-monetary) that shall be 
available via OSA: 

• Query the current account balance and current reservations. 

• Monitor account access (send notifications if charges or recharges are applied to a subscriber's account). 

• Retrieve the history of the transactions 



Journalling requirements 



Applications, that use the OSA interface, may perform actions in the network that might cause costs or potentially 
undesired effects to the user or operator. Therefore it shall be possible to log usage of the OSA interface and thus to 
make actions performed through the OSA interface traceable to their originating applications. 

Journal Information shall at least consist of the following parts: 

- Unique identity of the application 

Date and time of invoking execution of an OSA function 

Name of invoked OSA function 

Identity of the served subscriber. 

Additional information may be provided by the application (e.g. name of the service or reference to an application in the 
terminal). 

The OSA shall offer sufficient capabilities to: 

Request an application to supply the network with the application's Journal Information. The network operator 
may decide on the level of granularity (i.e. with which OSA functions Journal Information shall be provided). 

Reject execution of OSA functions if insufficient or inaccurate Journal Information is provided by the 
application. 

Supply a (logging-)application with Journal Information collected from various applications. 

Collection of Journal information may take place in the network or by a dedicated application using the OSA interface 



10 Security requirements 

10.1 Security requirements on User Profile IVIanagement 

The User Profile Management functions shall be able to grant or deny access to individual parts of the subscriber's User 
Profile as described in the clause 7. 

The User Profile Management functions shall ensure that all operations on parts of User Profile data are authorized. 

The type of access is one out of: 

Reading user profile information; in case parts of the User profile is subject for reading it shall unambiguously 
be identified by the application. 

Adding information to the user profile. 

Modify existing information in the user profile. 
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The control of access rights are in principle on the user's discretion. The user shall have the possibility to allow or 
restrict the retrieval and presentation of her user related data. The mechanism how a user is able to maintain access 
rights is for further study. 



1 1 Requirements for Policy IVIanagement 

Applications shall have the ability to interact with policy-enabled Service Capability Features in a secure manner. The 
network policies always take precedence over the application defined policies. 

The OSA interface shall provide sufficient capabilities to enable applications to request: 

To manage the application's policy-related information 

This allows applications to create, modify and delete policies, policy events and to activate and deactivate 
policy rules. 

To manage policy event notification 

This allows applications to register for specific policy events. Once registered for such events, the application 
shall receive notification of the events until it explicitly requests the termination of the notification request 

To collect policy statistics 

This allows an application to collect policy related statistics from the network. Examples include success or 
failure of operations on policies and time stamps of policy events. 



12 Event Notification Function 

The Event Notification Function shall allow an application to specify the initial point of contact which it is interested in. 
The Event Notification Function provides the necessary mechanisms which enables an application to request the 
notification of subscriber or network related event(s). An application may in addition request the cancellation of 
subscriber or network related event notification. For all subscriber related events the application shall always specify the 
subscriber for which the Event Notification Function is valid. Once an application has enabled the notification of 
event(s), the Event Notification Function shall report the event(s) until such time the application explicitly requests the 
termination of the event(s) notification. 

When the event occurs, the application that requested the event is informed.. The notification of the event shall be 
accompanied by unambiguous information identifying the original request and event related data.. For example, in case 
of an application is interested in "message" the notification to the application shall indicate whether it is incoming or 
outgoing, in case of chargeable events, the application shall receive details as used at the network to create a Call Detail 
Record. In this case, processing in the network is not suspended after notification of the event to the application. 

The Event Notification Function includes the availability of offering additional criteria to be specified by the 
application. The set of criteria is individual and may vary for the event requested. The detailed set of criteria available 
for each of the events below are described in [6]. 



12.1 Subscriber Related events: 



• An initial call processing event occurs. 

when a call to or from a given user is created and this event is armed by an application, that application shall 
be notified. 

• A message is sent or received. 

when a message to or from a given user is sent or received and this event is armed by an application, that 
application shall be notified. 

• A chargeable event happens. 
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when a chargeable event occurs for a given user and this event is armed by an application, that application 
shall be notified. 

• The user's status is changed. 

when a subscriber registers to a network or when a given user changes her status (e.g. from idle to busy) and 
this event is armed by an application, that application shall be notified. Registration in this sense is further 
detailed in the chapter on User Status Functions. Attach and detach applies for CS and PS. 

• The user's location is changed. 

when a given user changes her location (e.g. leaving a certain area which is "identifiable" by the network) 
and this event is armed by an application, that application shall be notified. 

• The Terminal Capabilities are changed. 

when the capabilities of a terminal change (e.g. when a keyboard is attached) and this event is armed by an 
application, that application shall be notified. 

Note: The ability to support this function is dependent on the ability of a terminal (through e.g. MExE or WAP) 
to notify changes in its capabilities. Therefore this function will not be able to supply event notifications 
for terminals not supporting notification of their terminal capabilities. 

12.2 Network Related Events: 

• A network fault management condition is met, 

when a fault management condition occurs at the underlying network (e.g. congestion of network 
components) and this event is armed by an application, that application shall be notified. 

• A network service or network service capability de-registers, 

when a network service capability feature de-registers with the Framework all applications which are 
currently authorised to use this service capability feature shall be notified. 

12.3 Other Related Events: 

• A change in presence related information. 

If any presence related information changes (such as one or more presence information attributes or a user's 
availability), and this event is armed by the application, that application shall be notified. Presence 
information may be associated with a user, device or service, or any abstract entity that has the ability to 
report presence information. 



13 Functions offered by OSA 



Functions that are offered by OSA shall be applicable for a number of different business and applications domains 
(including besides the telecommunication network operators also service provider, third party service providers acting 
as HE-VASPs, etc.). 

All of these businesses have different requirements, ranging from simple telephony and call routing, virtual private 
networks to fully interactive multimedia to using MS based applications. 

Service Capability Features: 

Application/Clients access OSA functions in terms of service capability features via the standardised application 
interface. This means that service capability features are accessible and visible to application/clients via the 
method/operation invocations in the interface. 

Service capability features shall be defined as much as possible in a generic way to hide the network specific 
implementation. To achieve this, it is necessary to identify the functionalities that can be provided in different ways by 
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the use of different service capabilities. For example, User Location can be produced in several underlying ways. Each 
of these functionalities can then be defined as a single generic function and the different underlying service capabilities 
are not visible to the application. It is important that the generic part becomes as large as possible to enable applications 
to use functions without the need for knowledge of the underlying network capabilities 

When applications use the generic service capability features, these applications become independent of the network 
domain ie network agnostic. Applications shall however still be able to request service capability features specific to a 
service capability (e.g. Call Setup from CAMEL) or specific to a particular network domain. This will increase 
dependency of the application on the used service capability while providing improved optimisation. 

Note: The grouping of OS A functions into Service Capability features is out of scope of this document. 

Three different types of OS A functions can be distinguished: 

Framework functions: provide commonly used utilities, necessary for access control, security, resilience and 
management of OS A functions; 

Network functions: these shall enable the applications to make use of the functionality of the underlying 
network capabilities. 

User Data related functions: these enable applications to access data of a particular user. Such data are e.g. the 
status of the user, her location or data in the user's User Profile. 

13.1 The Framework functions 

The framework provides the essential capabilities that allow OS A applications to make use of the service capabilities in 
the network. There are three distinct features that comprise the framework: Trust and Security Management, Service 
Registration and Discovery functions and Integrity Management. 

13.1.1 Trust and Security Mangement 

The trust and security management feature provides the necessary mechanisms which define the security parameters in 
which client applications may access the network. This includes the availability of a framework initial access point 
through which all client applications are authenticated and authorised and the ability to allow the signing of on-line 
service level agreements between the client applications and the framework. 

13.1.1.1 Authentication 

Authentication is used to verify the identity of an entity (user, network, and application). 
Three types of authentication are distinguished: 

• User-Network Authentication: 

Before a user can access her subscribed applications, the user has to be authenticated by the network that 
provides access to the application. This allows the network to check to what applications the user has 
subscribed to. User-network authentication is handled within the network and therefore outside the scope of 
the present document. 

• Application-Network Authentication: 

Before an application can use the capabilities from the network, a service agreement has to be established 
between the application and the network. Establishment of such a service agreement starts with the mutual 
authentication between application and network. If a service agreement already exists, modification might be 
needed or a new agreement might supersede the existing. 

• User- Application Authentication: 

Before a user can use an application or perform other activities (e.g. modifying profile data) the application 
must authenticate the user. When the network already authenticates the user, authentication is not needed 
anymore. When the network is transparent and the user accesses an application directly, authentication is 
needed between user and application but this is outside the scope of the present document. 
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13.1.1.2 Authorisation 

Authorisation is the activity of determining what an authenticated entity (user, network, and application) is allowed to 
do. 

NOTE: Authentication must therefore precede authorisation. 

Two types of authorisation are distinguished: 

• Application-Network Authorisation: 

Verifies what non-framework functions the application is allowed to use. Once an application has been 
authorised to use one, more or all non-framework functions no further authorisation is required as long as the 
"allowed" non-framework functions are used. 

• User- Application Authorisation: 

The application verifies what actions the user is allowed to perform (e.g. deactivation of functionality, 
modification of application data). This is transparent to the network and therefore outside the scope of the 
present document. 

13.1.2 Service Registration feature 

The Registration function enables the non-framework service capability features (i.e. service capability features that 
contain non-Framework functions) to register with the Framework. Registration must take place before authorised 
applications can find out from the Framework which non-framework service capability features are available. This 
means that the non-framework service capability features must be registered before they can be discovered and used by 
authorised applications. The service capability feature is finally registered if the registration process is successfully 
completed. 

Note that only the non-framework service capability features have to be registered. The Framework service capability 
features (containing only Framework functions) are available by default since they provide basic mechanisms. 

13.1.3 Service De-Registration function 

The De-Registration function enables the non-framework service capability features (i.e. service capability features that 
contain non-Framework functions) to de-register with the Framework. When a service capability feature de-registers 
the service capability feature shall discontinue providing service to all applications. Further, the service capability 
feature can no longer be discovered. 

13.1.4 Service Discovery feature 

The Discovery function enables the application to identify the total collection of service capability features that it can 
use. Upon request of the application, the Discovery function indicates the non-framework service capability features 
that are available for use by the application. The list of available service capability features is created through the 
Registration process described in subclause 12.1.2. This means that a service capability feature must be registered at the 
Framework before it can be discovered by the application. 

13.1.5 Integrity Management function 

Integrity management provides the means to allow the framework to query and report conditions that relate to the 
integrity of the framework, the network service capability features and the client applications. Furthermore an 
application may query conditions that relate to the integrity of the framework ad the network service capability features 
and report on it's own conditions. As part of the integrity management functions, the framework may provide: 

• supervision of the status of client applications to ensure continued operation, a process known as heartbeating. 

• fault management reporting and control. Specific examples include the ability for the framework to notify 
applications of internal fault conditions as well as faults in the network service capability features and the 
ability for applications to request specific test executions in the framework. 
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• operations and maintenance access, more specifically, the ability for the application to synchronise with the 
system date and time. 

13.2 Network functions 

The Network functions represent the total collection of network resources. 

The following subclauses define generic network functions e.g. for Session Control and Message Transfer. 

13.2.1 Call Control functions 

This subclause details with Call Control functions. The purpose of this function is to allow applications to control and 
monitor calls, both circuit and packet switched. 

The application may request the quality of service when first negotiated at the start of the call and may also request the 
network to notify the application of any changes in QoS (conversational, background, interactive and streaming class - 
see [4]) which take place during the call. 

For QoS information, the Call Control Function allows applications to monitor the amount of used traffic channels and 
bandwidth (e.g. for HSCSD) and used timeslots (e.g. for GPRS). 

1 3.2.1 .1 CS Call Control functions 

This subclause details with circuit switched call control functions. The purpose of this function is to allow applications 
to control and monitor calls. 

Applications should have the ability to : 

• Release Calls: 

This provides the ability for the application to force the release of a call. The application may provide an 
indication of the reason for release of the call. 

• Control Calls: 

This provides the ability for an application to modify the information pertaining to the call at the time of 
establishment of the call. The application may also allow the call to continue with or without the modified 
information pertaining to the call. The application shall have the ability to request call events of the call 
under control to be observed by the network and reported back to the application. 

• Request call information: 

This provides the ability for an application to request information relating to the call of interest specified in 
advance. Requested information includes at least call duration, call end time. 

• Monitor calls: 

This provides the ability for an application to monitor for call duration and tariff switching moments. An 
application may specify a threshold for the duration of a call or a part thereof. The application shall have the 
ability to grant new thresholds when the expiry of a previously set threshold has been reported to the 
application. When an event is subject to be monitored and the event is met, the application shall get informed 
accompanied with sufficient information. 

• Presentation of, or restriction of, information associated with a party involved in a call (e.g. calling line ID, 
calling name); 

• Relinquish control over a call 

This allows an application to relinquish control over a call but still allowing the established call to continue. 
Once the control of the call has been relinquished, the application may not be able to regain control over that 
call. 

• Interact with a user 
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This provides the ability for an application to interact with a user. An application may be able to send specific 
information to the user and may request the collection of data from the user. Sending information to the user 
or collecting information from the user shall be supported when the user is engaged in a call (e.g. USSD, 
DTMF) or call-unrelated (e.g. USSD, SMS). The information sent to the user may include an indication of an 
announcement, text or user specific data. 

Note 1: Call related user interaction may e.g. be used to play/record/customise user specific announcements while 
through call-unrelated user interaction e.g. service preferences may be managed. 

For each call it shall be possible to specify: 

the events on which monitoring is required ([10]). 

Note 2: The mapping to service capabilities is for further study (it shall be investigated to which extend the 
requirements above fit to CAMEL, MEXE and other service capabilities). 

13.2.1.2 PS Call Control functions 

This subclause details with packet switched call control functions. The purpose of this function is to allow applications 
to control and monitor GPRS sessions. A GPRS Session may consists of one or more GPRS PDP context. 

Applications should have the ability to : 

• Release a PDP context: 

This provides the ability for the application to force a PDP context to be released. The application may 
provide an indication of the reason for release of the PDP context. 

• Control a PDP context: 

This provides the ability for an application to modify the information pertaining to the PDP context at the 
time of establishment. The application may also allow the PDP context to continue with or without the 
modified information pertaining to the PDP context. The application shall have the ability to request events 
to be observed by the network and reported back to the application. 

• Monitor a PDP context: 

This provides the ability for an application to monitor for PDP context duration and tariff switching 
moments.. An application may specify a threshold for the duration of a PDP context or a part thereof. The 
application shall have the ability to grant new thresholds when the expiry of a previously set threshold has 
been reported to the application. 

• Monitor a GPRS session: 

This provides the ability for an application to monitor for GPRS session data volume. An application may 
specify a threshold for the amount of data allowed to be transferred within a GPRS session. The application 
shall have the ability to grant new thresholds when the expiry of a previously set threshold has been reported 
to the application. 

1 3.2.1 .3 IM Session Control functions 

Session Control 

Create Multi-media Sessions 

The application shall be able to establish sessions between two or more parties with certain media capabilities. 
The application may add or remove parties at any time for any session. An application may add additional 
sessions with certain media capabilities between any parties already involved in an session. Sessions with 
multiple parties may lead to the creation of a Multi-media Conference Call. This can either be an ad-hoc 
conference creation or it can refer to resources that were reserved in advance. 

Release Multimedia Sessions 

This provides the ability for an application to force the release of a multimedia session. This may be limited to 
the release of certain parties from the session or may be the release of all the parties. 
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Relinquish control over session 

This allows an application to relinquish control over the session. 

Party join/leave control 

The application shall be informed when a new call party wants to join/leave the conference. It shall be possible 
for the application to allow or reject the inclusion of the new party to a conference. 

Presentation of, or restriction of, information associated with a party involved in a session (e.g. caUing Une 
ID, calUng name); 

Media Control 

Control media channels 

The application shall have the ability to control media channels originated by (or on behalf of) a user or media 
channels terminated to a user. This control includes, but is not limited to the barring of a media channel request, 
allowing the media channel establishment to continue with or without modified information, addition or removal 
of additional media channels, temporarily suspend a media channel (place on hold), open, close or modify the 
parameters of the media channels. 

Relinquish control over specific media channels 

This allows an application to relinquish control over the media stream. When it relinquishes control over certain 
media channels it does not lose control over the entire session. 



Reserve/Free conference resources 

The application shall be able to reserve resources in the network or free earlier reserved resources for a 
conference in advance. 

Information 

Request Notification of Media channel events 

The application shall be able to request notification of certain events associated with a type of media channel. 
Events include, but not limited to: a user initiating or closing a session, an incoming session request to user or a 
terminating user unable to accept an incoming session request. 

Monitoring of Media channels 

The application shall be able to request all the media channels currently available on a session In addition the 
application must be able to monitor the opening and closing of channels for media for a specified session. 

13.2.2 Void 

1 3.2.3 Information Transfer function 

The Information Transfer function shall enable an application to indicate to a user, or toan application in the UE or 
USIM about the presence of existing information for the user. Physically, this indication may be sent by the underlying 
network e.g. as a SMS or USSD message to the terminal. The Information Transfer function provides the means to 
inform the underlying network that an indication shall be sent to the user. 

NOTE: For 3GPP mechanisms like USSD or SMS may be employed to transfer the indication to the users 
terminal. 

The following functions shall be supported: 

- send information notification: 

the Send information notification function provides the means to inform the underlying network that an 
indication shall be sent to a user, or to an application in the UE or USIM about the presence of existing 
information for the user; 

- request message receipt notification: 



£75/ 



3GPP TS 22.1 27 version 5.3.0 Release 5 21 ETSI TS 1 22 1 27 V5.3.0 (2002-03) 

the application can request to receive a notification every time a message is received in the mailbox for the 
user. This allows the application to take the appropriate action, e.g. informing the user. 

13.2.4 Charging functions 

Call and Event Charging 

Call and Event Charging functions enable the application to instruct the network and inform the user with charging 
information and to add some additional charging information to the network generated Call Detail Records. Some of the 
following charging facilities are available only if the network either controls the account or has access to it. 

The OSA Call and Event Charging function shall enable an application to: 

define and manage thresholds (e.g. session duration, data volume) for a call; 

provide additional charging information to be included in the Call Detail Record. This may contain information 
transparent to the network; 

transfer Advice of Charge data (as defined in [5]) to the terminal. 

Service Usage 

These charging functions shall enable applications to augment subscriber accounts maintained by the network and to 
charge subscribers for using services. These applications are not necessarily telecommunication related. In addition to 
charging subscribers for service usage, these functions could also be used for payments in an online purchase scenario. 

Provided, that these functions are supported by the underlying network an application shall be able to: 

Check, if - for the service to be provided by the application - the charge is covered by the subscribers account or 
credit limit 

Reserve - for the service to be provided by the application - a charge in the subscribers account, that can be 
deduced from the account after service delivery. 

Deduct an amount from the subscriber's account. If a reservation has been made earlier, this amount should be 
taken from the reserved amount. 

Request the network to split the deduction of an amount among several subscribers accounts or other chargeable 
entities according to a specified partitioning. It shall be possible to notify an individual subscriber's account or 
other chargeable entity about the percentage of the total amount, to which the deduction has been performed 
Note: this requirement also covers the case when the total amount to be deduced is calculated by the network. 

Release a reservation acquired earlier. If part of a reservation has been deducted already, just release the 
remaining reservation. 

Add non-monetary units to a subscriber's account. 

Deduct non-monetary units from a subscriber's account. 

Reverse a completed charge transaction, e.g. after repudiation. 

The functions for charging application usage shall meet the following general requirements: 

Hide payment policy (e.g. prepaid/postpaid) from applications 

Hide payment type (credit card, cash, bank withdrawal) from applications 

Hide subscriber's identity towards the application. This would provide anonymity (like for prepaid customers). 

Support prepaid subscribers. This requires that the application immediately gets informed if the subscriber's 
account covers the service usage costs. If not, the application may reject serving the subscriber. 

Allow for Multi-currency support. This shall allow service providers to request charging in their preferred 
currency 

General Account functions 
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These functions provide access to sensitive data. They shall be restricted to client applications that had been granted 
additional privileges via suitable means, i.e. as authorised by the framework function. 

The OSA general Account function shall enable an application to: 

retrieve a transaction history of a subscriber's account, this may include 

the retrieval of a list of monetary or non-monetary amounts that have been debited from or credited to a 
subscribers online account, 

the request of additional information on the specific transaction (e.g. the application or service description 
provided with the actual transaction). 

check a subscriber's current account balance. 

monitor the subscribers account and may request to get informed of any change. 

ask the charged user for an explicit, interactive confirmation before any charging operation is performed. The 
General Account function will support a procedure to obtain confirmation by the user. Such a procedure shall be 
under the control of the network. 

Note: There is no requirement to standardise this procedure. 

In case an application retrieves a list for a subscribers' transaction history, it shall specify the time interval for which the 
transaction history shall be retrieved. 

1 3.3 User data related functions 

1 3.3. 1 User Status functions 

The User Status functions enable an application to retrieve the user's status, i.e. to find out on which terminals the user 
is available. 

The following functions shall be provided: 

- retrieval of User Status: 

the application shall be able to retrieve the status of the user (e.g. the user is busy, her terminal is attached, or 
detached). 

- notification of User Status Change: 

the application shall receive notifications when the user's terminal attaches or detaches: 

detach: the user's terminal is switched off or the network initiates detach upon location update failure; 

attach: the user's terminal is switched on or there has been a successful location update after network 
initiated detach. 

the application shall receive notifications when the user's status moves from idle to busy, or from busy to 
idle. 

Attach and detach applies for CS and PS. 

The application shall be able for each terminal to start/stop receipt of notifications. 

1 3.3.2 User Location functions 

The User Location functions provide an application with information concerning the user's location. 
The user location information contains the following attributes: 

location (e.g. in terms of universal latitude and longitude co-ordinates); 
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accuracy (value depending on local regulatory requirements and level of support in serving/home networks; 
note that the accuracy of the serving network might differ from that in the home environment); 

age of location information (last known date/time made available in GMT). 

The following functions shall be provided: 

- report of location information: 

the application shall be able to request user location information; 

by default the location information is provided once; the application may also request periodic location 
reporting (i.e. multiple reports spread over a period of time). 

- notification of location update: 

the application shall be able to request to be notified when the user's location changes, i.e. when: 

the user enters or leaves a specified geographic area; 

the user's location changes more than a specified lower boundary. The lower boundary can be selected 
from the options provided by the network. 

The application shall be able for each user to start/stop receipt of notifications and to modify the required accuracy by 
selecting another option from the network provided options. 

- Access control to location information: 

the user shall be able to restrict/allow access to the location information. The restriction can be overridden by 
the network operator when appropriate (e.g. emergency calls). 

1 3.3.3 User Profile Management functions 

No requirements for this release are identified. 

1 3.3.4 User Profile access Authentication/Authorisation functions 

No requirements for this release are identified. 

13.3.5 Terminal Capabilities functions 

The Terminal Capabilities functions enable the application to determine the capabilities of the user's terminal . 

Note 1: The ability to support this function is dependent on the ability of a terminal (through e.g. MExE or WAP) 
to notify its terminal capabilities. Therefore this function will not be able to supply terminal capabilities 
for terminals not supporting notification of their terminal capabilities. 

Note 2: "Terminal" covers both (mobile) equipment and USIM. 

The following functions shall be provided: 

- retrieval of Terminal Capabilities: 

the application shall be able to retrieve the capabilities of the terminal. This includes: 

the media that the terminal is capable to deal with (e.g. audio, video, ; this information is needed by the 
application e.g. when the user wants to download messages from the mailbox); 

the number of calls/sessions that the terminal can deal with simultaneously. 

13.3.6 Functions for retrieval of Visited Network Capabilities 

OSA applications make use of network capabilities offered through the abstraction of the service capability features. As 
a user may be served by network capabilities in a VPLMN, applications may benefit from knowing the differences that 
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exist between the home and visited network capabilities. Such information may provide the ability for an application to 
tailor its behaviour according to the capabilities of the visited network. 

The functions for retrieval of Visited Network Capabilities shall enable the application to obtain information about the 
network capabilities of the visited network serving a subscriber. 

The information provided to the application shall contain the following, if available: 

Available network toolkits, including level of support (e.g. CAMEL Phase X) 



Supported Network access, (e.g. GPRS, CS, IMS), and in case of no support, detailed information (unknown 
support, roaming not allowed, ...). 

13.4 Information Services functions 

The information services functions enable applications to supply information that is available for later retrieval from 
applications as determined by the Home Environment. 

NOTE: The HE is not requested to broadcast service information received from OSA applications to any 
application or user. 

The HE shall be able to restrict the maximum size of information supplied by OSA applications. The information is 
kept in the HE for retrieval by OSA applications. The HE provides the information on OSA application request. The 
main purpose is to pass textual information between OSA applications. 

The information itself shall clearly allow to be classified in HE-defmed categories. Examples of such categories could be 
traffic information, weather, headlines, local services, etc. 

The following functions shall be provided:- 

- supply and update of Information: 

the application shall be able to supply and update details to the information service in order to make it 
available to other applications 

this action may take place by application's own initiative, or when requested by the network 

- retrieval of Information: 

the application shall be able to retrieve details from the information service 

1 3.5 Presence related capability functions 

The OSA interface shall allow an application access to presence capabilities within the network. Presence related 
information may be requested or supplied by an OSA application and may include, but not limited to presence 
information pertaining to the presence service as described in [7] or user availability. 

An OSA application may act as a requester of presence information (i.e. act as a watcher) and/or act as a supplier of 
presence information (i.e. act as a presentity). All the capabilities offered to presence service watchers and presentities 
are described in [7] and may be offered to OSA applications. In addition to the authorisation performed by the OSA 
Framework, the presence service checks that the application is permitted to access the presence service. 

An OSA application may manage or query availability status and/or preferences of a user which may be associated with 
one or more services (e.g. voice call, IMS sessions, MMS ...etc.). Such availability may be determined from a range of 
existing capabilities. 

The following OSA capabilities shall be supported for an application: 

- register as a presentity and/or watcher: 

the application shall be able to request the registration as a presentity and/or as a watcher in the presence 
service. This registration shall include the ability to establish as well as cancel a registration. 
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Note : Registration of a watcher is not covered in TS 22.141 and hence FFS. 

- supply presence related information to the network: 

the application shall be able to supply and/or update presence related information (presence information or 
availability) at any time. An application may modify the availability of a user. - request the querying 
and/or modification of presence related data: 

the application shall be able to request the querying and/or modification of data other than presence 
information related to watchers and/or presentities. Such data includes, but is not limited to any access rules 
pertaining to the presentity to be modified. An application may be able to request the management of 
availability preferences of a user. Management includes the setting, modification and deletion of availability 
preferences. 

- request Presence related Information : 

the application shall be able to request presence related information. The application shall be able to request 
presence information about a presentity or may request the availability of a user. Such requests may be for 
the current information, on a periodic basis or for future changes in the presence related information (e.g. 
arming of event notifications). 

- retrieve watcher information: 

the application shall be able to request watcher information about a presentity. 
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Annex A (informative) : Use cases 



This informative annex describes how the OS A functions described in the normative section of this document could be 
used to deploy enhanced multimedia services. 



A.1 Service Scenario Description 



The service scenario described below is the following: a user has subscribed to a tourist board information service, and 
each time he will enter a new interesting location the service provider will offer him to watch a video showing the main 
attractions of the area. The service is charged 1 Euro per movie. 



A.2 Step by step description 



Note: The following description does not imply any physical location of the different functions, or any mapping 
between the SCFs and the network capabilities. The processes internal to the different entities are not 
detailed. 

FF: Framework Function 

NF: Network Function 

UF: User data related Functions 

Step 1: On-line Service Level Agreement 

This step is intended to sign an on-line service level agreement (SLA) between the information service and the 
framework. 



♦ 



Service 
Provider 



OSA SCFs 



FF - Application-Network Autiientication 
4 ► 



The Framework 
is authenticated 



The Service Provider 
is authenticated 



FF - AppUcation-Network Authorisation 
■* ► 



The list of non-framework functions the application is 
allowed to use is established. SLA is signed. 



Step 2: Service initialisation 

The Service Provider will discover all the service features available in the network (e.g. location update, service usage 
charging. . .), and set up the parameters necessary to render the service (i.e. the service provider asks to be notified 
whenever the user enters a specific geographic area). The list of available service features depends on the SLA. 

Note: It is assumed that all the available Service Capability Features have already registered. 



Step 3: Service Delivery 

The service provider is informed that the user has entered a new geographical area (e.g. Japan). After checking that the 
user has enough money left on his account, the service provider retrieves the terminal capabilities. Based on this 
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information, the service provider can determine the type of content that can be sent to the user (for example a black and 
white video if the terminal does not support colour display, . . .). The service provider will then reserve 1 in the account 
of the subscriber. A multimedia session will be established between the service provider and the user, and the user wiU 
then be displayed the sightseeing information. Once the movie's display is over, the session will be released and the 
service fee will be deducted from the user's account. 



♦l 



Service 
Provider 



OSA SCFs 



UF - Report of Location Update 

NF - Charging Function - Service Usage - Clieclc solvency 

UF - Retrieve Terminal capabilities (media available, screen size. . .) 




/- ' ^ 

The service provider 
identifies which type 
of video can be 
delivered to the user. 

V 



NF - Charging Function - Service Usage - Reserve 
NF - Create Multi-media session 



NF - Release Multimedia Session 




NF - Charging Function - Service Usage - Deduct 1 Euro 
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